import request from "@/utils/request";

const WORDS_BASE_URL = "/api/v1/words";

const WordsAPI = {
    /** 获取单词信息分页数据 */
    getPage(queryParams?: WordsPageQuery) {
        return request<any, PageResult<WordsPageVO[]>>({
            url: `${WORDS_BASE_URL}/page`,
            method: "get",
            params: queryParams,
        });
    },
    /**
     * 获取单词信息表单数据
     *
     * @param id 单词信息ID
     * @returns 单词信息表单数据
     */
    getFormData(id: number) {
        return request<any, WordsForm>({
            url: `${WORDS_BASE_URL}/${id}/form`,
            method: "get",
        });
    },

    /**
     *  添加单词信息
     *
     *  @param data 单词信息表单数据
     */
    add(data: WordsForm) {
        return request({
            url: `${WORDS_BASE_URL}`,
            method: "post",
            data: data,
        });
    },

    /**
     * 更新单词信息
     *
     * @param id 单词信息ID
     * @param data 单词信息表单数据
     */
     update(id: number, data: WordsForm) {
        return request({
            url: `${WORDS_BASE_URL}/${id}`,
            method: "put",
            data: data,
        });
    },

    /**
     * 批量删除单词信息，多个以英文逗号(,)分割
     *
     * @param ids 单词信息ID字符串，多个以英文逗号(,)分割
     */
     deleteByIds(ids: string) {
        return request({
            url: `${WORDS_BASE_URL}/${ids}`,
            method: "delete",
        });
    }
}

export default WordsAPI;

/** 单词信息分页查询参数 */
export interface WordsPageQuery extends PageQuery {
    /** 所属单元ID */
    unitId?: number;
}

/** 单词信息表单对象 */
export interface WordsForm {
    /** 单词ID */
    id?:  number;
    /** 拼写 */
    spelling?:  string;
    /** 音节 */
    syllable?:  string;
    /** 中文释义 */
    meaningZhCn?:  string;
    /** 英文例句 */
    exampleEnUs?:  string;
    /** 中文例句 */
    exampleZhCn?:  string;
    /** 所属单元 */
    unitName?:  string;
    /** 所属教材ID */
    programId?:  number;
    /** 所属系列ID */
    seriesId?:  number;
    /** 所属单元ID */
    unitId?:  number;
    /** 状态 */
    status?:  number;
}

/** 单词信息分页对象 */
export interface WordsPageVO {
    /** 单词ID */
    id?: number;
    /** 拼写 */
    spelling?: string;
    /** 音节 */
    syllable?: string;
    /** 中文释义 */
    meaningZhCn?: string;
    /** 英文例句 */
    exampleEnUs?: string;
    /** 中文例句 */
    exampleZhCn?: string;
    /** 所属单元 */
    unitName?: string;
    /** 所属教材ID */
    programId?: number;
    /** 所属系列ID */
    seriesId?: number;
    /** 所属单元ID */
    unitId?: number;
    /** 状态 */
    status?: number;
}
